0 
vo 

ro 

c 



o 



10 



IN THE UNITED STATES 
PATENT AND TRADEMARK OFFICE 



PATENT APPLICATION 

Jose' C. Brustoloni 
Juan Alberto Garay 



CASE 10-6 

TITLE Method And Apparatus For Extending Network Address Translation For Unsupported Protocols 

ASSISTANT COMMISSIONER FOR PATENTS 
WASHINGTON, D.C. 20231 

SIR: 

NEW APPLICATION UNDER 37 CFR § 1, 53(b) 

Enclosed are the following papers relating to the above-named application for patent: 
Specification 

7 Informal Sheets of drawing(s) 
Information Disclosure Statement 



o 

HO\ = 



5o 



CLAIMS AS FILED 




NO. FILED 


NO. EXTRA 


RATE 


CALCULATIONS 


Total Claims 


63 - 20 = 


43 


x$18 = 


$774 


Independent Claims 


9-3 = 


6 


x$78 = 


$468 


Multiple Dependent 
Claims, if applicable 






+ $260 = 


$260 


Basic Fee 




$690 




TOTAL FEE 


$2192 



Please file the application and charge Lucent Technologies Deposit Account No. 12-2325 the amount 
of $21 92, to cover the filing fee. Duplicate copies of this letter are enclosed. In the event of non-payment 
or improper payment of a required fee, the Commissioner is authorized to charge or to credit Deposit 
Account No. 12-2325 as required to correct the error 



The Assistant Commissioner for Patents is hereby authorized to treat any concurrent or future reply, 
requiring a petition for extension of time under 37 CFR § 1.136 for its timely submission, as incorporating 
a petition for extension of time for the appropriate length of time if not submitted with the reply. 

Please address all correspondence to Docket Administrator (Room 3C-512), Lucent Technologies 
Inc., 600 Mountain Avenue, P.O. Box 636, Murray Hill, New Jersey 07974-0636, However, telephone 
calls should be made to me at 908-582-7038. 



Date: 



11^ n^oao 



Lucent Technologies Inc. 

600 Mountain Avenue (Room 3C-512) 

P.O. Box 636 

Murray Hill, New Jersey 07974-0636 



Respectfully, 




Stephen M. Gurey 
Reg. No. 27336 
Attorney for Appiicant(s) 




Date of Deposit O^-^li^^KM^ 
\ hereby cert^S/ that x\C\% p,tPUtd. WN u 
being deposited with the United Slat^Post^ 

Service "E?;press Mail Post Office to 
Addressee" s-n'ice tender 37 CFR 1.10 on the 
d:^te indicated above and is addressed to the 
Con!xissioner of Patents and Trademarks 

"'•'"■^5?g">.r7fe/»4 .? 

(Printed^ame of pe^SQ^f mailing pappr or fee) 
rson mailing paper or fee) 




^"Srustoloni 10-6 



METHOD AND APPARATUS FOR EXTENDING NETWORK ADDRESS 
TRANSLATION FOR UNSUPPORTED PROTOCOLS 

Cross-Reference 

5 This application claims the benefit of U.S. Provisional Application No. 

60/162090, filed October 28, 1999. 

This application also describes and claims subject matter that is in co- 
pending United States patent application filed simultaneously herewith and 
entitled: "METHOD AND APPARATUS FOR APPLICATION-INDEPENDENT 
10 END-TO-END SECURITY IN SHARED-LINK ACCESS NETWORKS," Serial No. 



Technical Field 

This invention relates to packet-based data communications on IP 
15 networks, and more particularly, to network address translation that enables 
communications between clients on a shared line or private network and servers 
on a global network such as the Internet. 

Background of the Invention 

20 A plurality of clients can share a single access link to the Internet or other 

IP network by using network address and port translation (NAT). In accordance 
with NAT, the clients on a private network are assigned individual IP addresses 
from a pool of IP addresses reserved by the Internet Assigned Numbers 
Authority (lANA) for non-exclusive private network use. Private addresses are 

25 not routable on the Internet. When a client on the private network wants to 

communicate with a server on a global network, such as the Internet, a globally 
unique and routable IP address must be used instead of the client's local non- 
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routable private IP address. Typically, a private network is connected to the 
Internet via a router and shared access link to an Internet Service Provider (ISP). 
NAT is a feature that may be implemented in the router and that provides 
unambiguous translations between private and global addresses, allowing the 

5 plural clients to share the access link. When a client sends a packet to a foreign 
address (i.e., one not in the private network), NAT modifies the packet header, 
substituting the client's private source IP address and generalized port number 
(GPN) by a global IP address and GPN. Depending upon the protocol being 
used, GPN is a certain field in the packet header. For example, for the TCP or 

10 UDP protocols, the GPN is the TCP or UDP port number. For other protocols, 
the GPN may be another field. A single global IP address may be shared as the 
source address of packets sent by all or some of the clients to the Internet. In 
order to properly route incoming packets sent from a foreign address on the 
Internet to a client on the private network, NAT maintains in a translation table, 

15 stored in memory, the one-to-one correspondence between private and global IP 
addresses and GPNs. When NAT receives a packet from the Internet, NAT 
modifies the packet header's destination from global to private (IP address, 
GPN) values, according the NAT's translation table, allowing the packet to reach 
the respective client in the private network. Some application-layer protocols 

20 may also include IP addresses and possibly port numbers in packet payloads. 
Such addresses and port numbers must also be similarly translated. For each 
such protocol, NAT includes an Application Level Gateway (ALG) program that 
provides these additional necessary translations. Furthermore, when the NAT 
performs its translations, the packet checksum in the transport layer TCP or UDP 

25 header of the packet is correspondingly modified to reflect the changes resulting 
from the translations. Thus, when the packet is eventually received at its 
destination, its checksum will be correct if there are no transmission errors. 
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The use of network address translation presents difficulties when it does 
not or cannot support a particular protocol that a client is desirous of using. As 
an example, certain security architectures have not been able to be fully 
interoperable with NAT. Security protocols are extremely useful in determining 

5 whether or not a received packet has been corrupted in some manner between 
the client/servers from which it is transmitted and received. In order to prevent 
packet forgery and snooping, authentication and encryption of packets may be 
used, respectively. Various security protocols may be used for authentication 
and/or encryption. Some protocols can be used in conjunction with NAT, for 

10 example the Secure Shell (SSH), Secure Sockets Layers (SSL), and Point-to- 
Point Tunneling Protocol (PPTP). Disadvantageously, however, SSH and SSL 
implement security in the application layer and are thus application-dependent, 
whereas PPTP's security is often considered deficient. On the other hand, IP 
Security (IPSec) operates at the network layer and therefore is independent of 

15 the transport- (e.g., TCP or UDP) or application-layer protocol (e.g., HTTP, FTP, 
or TELNET). It is thus application-independent and therefore capable of 
providing end-to-end security without modification to applications. Further, 
IPSec is vendor-independent and can provide end-to-end security. 
Disadvantageously, however, IPSec has been considered as not being 

20 interoperable with NAT. In fact, the literature has so stated (see, e.g., N. 
Doraswamy and D. Harkins, "IPSEC: The New Security Standard for the 
Internet, Intranets and Virtual Private Networks," Prentice-Hall, 1®* ed., July 
1999). 

IPSec is an Internet standard from the IETF IPSec Working Group (see, 
25 e.g., S. Kent and R. Atkinson, "Security Architecture for the Internet Protocol," 
IETF, RFC 2401, November 1998). IPSec is a mandatory part of the next- 
generation IP protocol (IPv6, see, e.g., S. Deering and R. Hinden, "Internet 
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Protocol, Version 6 (Ipv6) Specification," IETF, RFC 2460, December 1998), but 
most existing IPSec implementations assume current-generation IP (IPv4). 
IPSec is essentially an encapsulation protocol, namely one that defines the 
syntax and semantics of placing one packet inside another. IPSec defines two 

5 protocols, the Authentication Header (AH) protocol (see, e.g., S. Kent and R. 
Atkinson, "IP Authentication Header," lEFT, RFC 2402, November 1998) and 
Encapsulating Security Payload (ESP) protocol (see, e.g., S. Kent and R, 
Atkinson, "IP Encapsulating Security Payload (ESP)," lEFT, RFC 2406, 
November 1998). The AH protocol can provide authentication of packet origin, 

10 proof of integrity of packet data, and protection against packet replay. In addition 
to that which the AH protocol can provide, the ESP protocol can provide 
encryption of packet data and limited traffic flow confidentiality. The AH and ESP 
protocols can be used either in what are known as the transport or tunnel 
modes. The transport mode provides end-to-end security between the source of 

1 5 the packet and its destination. In contrast, the tunnel mode encapsulates 
packets and thus provides security between the nodes where the packet is 
encapsulated and decapsulated, which can be any nodes (e.g., routers) on the 
path between the source of the packet and its destination. Depending on the 
situation, clients might use different modes. Thus, for example, the transport 

20 mode may be used to download, via FTP, a document from a supplier's server, 
thus providing full authentication/security between the client and the server. On 
the other hand, the tunnel mode may be used by a client to connect to an IPSec 
gateway into an employer's Intranet. 

Several problems hamper the interoperation of IPSec and NAT. For the 

25 AH protocol, when NAT translates an address, it would need to correspondingly 
adjust, through an ALG, the packet's authentication data, which depends on the 
packet's address. If the authentication data is not adjusted the packet will be 
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rejected at the destination. In order for the NAT to modify the authentication 
data, however, the NAT would need to know the authentication key. Since that 
key is maintained private in order to protect the integrity of the security 
architecture, NAT is unable to modify the authentication data in the packet to 

5 compensate for the address translations. For the ESP protocol, interoperability 
with NAT is problematic in the transport mode. In the transport mode of the ESP 
protocol, when NAT translates the source or destination IP address, it would 
need to correspondingly adjust the TCP or UDP checksum, which is calculated 
over the packet's IP "pseudo-header," TCP or UDP header, and packet data. 

10 The pseudo-header includes the source and destination IP addresses. 

However, since the checksum is encrypted, along with the rest of the TCP or 
UDP header and data, NAT cannot make the necessary adjustment to this 
checksum without having access to the encryption key. For end-to-end security, 
the encryption key must not be revealed to intermediate nodes including NAT. 

15 Thus, NAT is not interoperable with the ESP protocol in the transport mode. 
A problem therefore exists with respect to using network address 
translation with protocols, such as IPSec, that the NAT does not or cannot 
support. 

20 Summary of the Invention 

In accordance with the present invention, the NAT is extended to be 
capable of providing network address translation of outgoing and incoming 
packets from and directed to clients, respectively, operating under a protocol that 
the NAT itself does not directly support such as, for example, IPSec. This is 
25 achieved with the extensible NAT of the present invention which, upon receiving 
a request from a client that defines for an unsupported protocol, a generalized 
port number (GPN) and its location within the packet. A global IP address and 
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global GPN are then assigned and associated with the client's private IP address 
and GPN for packets sent to and received from a specified foreign address. An 
entry is then installed in the NAT'S translation table, in memory, that defines for 
that protocol the association between the client's private IP address and GPN 

5 and the assigned global IP address and GPN for communication with the 
specified foreign address until a specified or default expiration time. Outgoing 
packets from a client using that protocol and having as a source address that 
private IP address and that private GPN and having that foreign address as their 
destination, will have their source address translated to the global IP address 

10 and their private source GPN translated to the global GPN, as defined by that 
entry in the translation table. Similarly, incoming packets using that protocol and 
having as their source address that foreign address, and having the global IP 
address as their destination address, will have their destination address 
translated to the private IP address and their destination GPN translated to the 

15 private GPN. Such translations in outgoing and incoming packets continue until 
the expiration time of the entry in the translation table, which may be extended in 
response to a request from a client. 

Since the NAT does not have an ALG for an unsupported protocol, an 
ALG that would otherwise be implemented at the NAT is implemented instead at 

20 the client to perform any necessary functions on the packet payload and/or 
headers. The client having a client-implemented ALG is therefore enabled to 
communicate with a foreign address using a protocol that is not directly 
supported by NAT. In particular, a security protocol suite, such as IPSec, which 
is incompatible with NAT due to the inability of NAT to perform necessary 

25 modifications within the packet, can be used in order to ensure end-to-end 
security. Besides implementing the necessary ALGs, the client pre- 
compensates outgoing packets before they are transmitted and post- 
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compensates incoming packets for the effects on the packets of the NAT's 
translations. The inclusion at the client of the necessary ALGs and pre and post 
compensation by the client is the subject of the afore-noted co-pending patent 
application Serial No. , filed on even date hereof. Specifically, 

5 for the IPSec protocol, each outgoing packet is modified by the client before 
being processed for authentication and encryption (the latter, if using ESP 
protocol) to pre-compensate for the effect of the NAT translations on the 
cryptographic or non-cryptographic checksums. Thus, when the packet is 
received at its destination and authenticated and decrypted (the latter, if using 

10 ESP protocol), the checksum calculated for that packet will be in accord with the 
transmitted checksum that was incorporated into and transmitted in the packet. 
Thus, absent a transmission error, the packet will not be dropped by the receiver. 
Specifically, before the packet is authenticated and encrypted (the latter, if using 
ESP protocol), private IP addresses and port numbers that NAT will not translate 

15 are replaced by corresponding assigned global values; the TCP or UDP 

checksum is modified to account for all the translations in the packet from private 
IP addresses and port numbers to global IP addresses and port numbers in such 
a manner that when NAT performs its translation operations and the packet is 
sent to its destination, the modified checksum matches, absent a transmission 

20 error, the actual checksum of the packet as operated on by NAT; and the AH 
authentication data (for AH protocol) is computed as if the source IP address 
were equal to the global IP address. For an incoming packet from the network, 
in a similar manner, the AH authentication data (for AH protocol) is computed as 
if the destination IP address were equal to the global IP address. After the 

25 packet is then authenticated and decrypted (the latter, if using ESP protocol) by 
the client, it is modified so as to post-compensate for the effect of the NAT 
translations on the cryptographic or non-cryptographic checksums. Specifically, 
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the client replaces those global IP addresses and port numbers in the packet 
that NAT has not translated with their corresponding private values . Further, the 
TCP or UDP checksum is modified to compensate for the translations made by 
the client and the NAT to the IP addresses and port numbers so that the 
5 modified checksum matches, absent a transmission error, the checksum 
calculated over the address-translated packet. 

Brief Description of the Drawing 

FIG. 1 shows a network architecture in which a plurality of clients are 
10 connected through a local high-bandwidth network to a local router/server, which 
is extensible to handle unsupported protocols such as IPSec and which performs 
the NAT operations that enable communication to and from the Internet; 

FIG. 2 shows the IPSec packet format for the AH protocol in the transport 

mode; 

15 FIG. 3 shows the IPSec packet format for the ESP protocol in the 

transport mode; 

FIG, 4 shows the IPSec packet format for the AH protocol in the tunnel 

mode; 

FIG. 5 shows the IPSec packet format for the ESP protocol in the tunnel 

20 mode; 

FIG. 6 shows an entry in a NAT translation table that enables 
unambiguous translation of IP addresses and port numbers by the NAT. 

FIG. 7 is a flowchart showing the steps performed by the extensible 
router/server of the present invention that enable it to process packets to and 
25 from a client using an unsupported protocol; and 
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FIG. 8-10 together are a flowchart detailing the steps, from a local client's 
standpoint, that provide interoperability with the extensible NAT router/server and 
NAT using the unsupported IPSec security protocol. 



5 Detailed Description 

With reference to FIG. 1, a plurality of clients 101-1 - 101-N are 
connected on a local network 102. The local network 102 can be an Ethernet, a 
WaveLAN, or any other private network to which a plurality of operative clients 
can be simultaneously connected. The local network 102 is connected to a local 

10 router/server 103, which in turn is connected over a shared high-bandwidth link 
104 to an ISP 105, which provides access to the Internet 106. Link 104 can be, 
for example, a cable, a DSL, or a T1 line. A hotel, an airport lounge, a 
conference center, are examples of facilities at which a shared link could provide 
Internet connectivity to a plurality of users for connection of their portable PCs. 

15 In order to enable the plural clients 101-1 - 101-N to share the link 104, each 
client is assigned a private IP address by the local router/server 103. As 
previously noted, the non-permanent IP addresses assigned to these clients are 
from the set of non-routable IP addresses allocated by lANA for private network 
use. Router/server 103 is assigned one or more routable IP addresses by ISP 

20 105. In order for the plural clients 101-1 - 101-N to share link 104, router/server 
103 incorporates NAT 107 software module. As previously noted, NAT 107 
translates the private IP address and GPN used by each client 101-1 - 101-N to 
a global address and global GPN associated with router/server 103. For the 
TCP or UDP protocol, for example, where the GPN is the port number, NAT 107 

25 translates in each outgoing packet from a client, its source private IP address 
and port number to a uniquely associated global IP address and port number. 
Incoming packets addressed to that global IP address and port number are then 
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translated back by NAT 107 to the local private IP address and port number of 
the particular client to which they are properly directed. In this manner, through 
the use of NAT, the plural clients 101-1 - 101-N can share the common link 
104. 

5 In order to prevent one client from forging or snooping on the packets sent 

or received from another one of the clients connected on the same private 
network, authentication and encryption can be used. As previously mentioned, 
IPSec can provide end-to-end security (authentication and/or encryption) without 
modifications to applications. In order to use an authentication/encryption 

10 security protocol suite such as IPSec, however, a client needs to modify each 
outgoing packet and incoming packet by performing IP address and GPN 
translations that the NAT 107 is unable to perform without having access to 
authentication and/or encryption/decryption keys, and by modifying a TCP or 
UDP checksum to compensate for the translations performed locally and by NAT 

15 107. Further, since NAT 107 cannot incorporate an ALG to perform those 
functionalities that need to be performed on the outgoing packets without 
corrupting the packet, an outgoing packet is operated upon by the source client 
of that packet to process any necessary ALG. In a similar manner, each 
incoming packet that originated at a server 108 connected on Internet 106 and is 

20 received by a client 101-1 - 101-N from the router/server 103, is post- 
compensated after the packet has been decrypted and authenticated. As in the 
outgoing case, the client operates on the resultant packet to process any ALG 
that needs to be performed and to perform translations of global IP addresses 
and global GPNs to local IP addresses and local GPNs that the NAT is unable to 

25 do, and to modify the TCP or UDP checksum to compensate for the translations 
made to the packet either locally by the client or by the NAT itself. Both the pre- 
compensation and post compensation, to be described in more detail herein 
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below, are effected through an IPSec/Nat interoperability client module 109 
included within each client 101-1 - 101-N. 

As previously nnentioned, the IPSec security format defines two protocols: 
the AH (Authentication Header) protocol and the ESP (Encapsulating Security 

5 Pay load) protocol. The AH protocol can provide authentication of packet origin, 
proof of integrity of packet data, and protection against packet replay. The ESP 
protocol can provide, in addition to the AH protocol's services, encryption of 
packet data and limited traffic flow confidentiality. The AH and ESP protocols 
can be used either in the transport or tunnel mode. The transport mode provides 

10 end-to-end security between the source of the packet and its destination. In 
contrast, the tunnel mode encapsulates packets and thus provides security 
between the nodes at which the packet is encapsulated and decapsulated. 
These nodes can be any nodes on the path between the packet's source and 
destination. FIG. 2 shows the packet layout for the AH protocol in the transport 

15 mode; FIG. 3 shows the packet layout for the ESP protocol in the transport 
mode; FIG. 4 shows the packet layout for the AH protocol in the tunnel mode; 
and FIG. 5 shows the packet layout for the ESP protocol in the tunnel mode. In 
the tunnel mode, in FIGS. 4 and 5, the encapsulated packets, 401 and 501, 
respectively, are shown in bold. The portion of the packet that is authenticated 

20 or encrypted is different for the AH and ESP protocols. The AH and ESP 
protocols insert a header (202 in FIG. 2 and 302 in FIG. 3) between the IP 
header and the upper-layer UDP or TCP header in the transport mode. In the 
tunnel mode the header (402 in FIG. 4 and 502 in FIG. 5) is inserted between 
the IP header and the encapsulated IP datagram. The ESP protocol also 

25 appends a packet trailer (303 in FIG. 3 and 503 in FIG. 5). In the tunnel mode, 
the IP header (404 in FIG. 4 and 504 in FIG. 5), may have source and 
destination IP addresses different from those of the encapsulated packet. In the 



11 



Brustoloni 10-6 

AH protocol, authentication covers the entire IP datagram, as can be noted in 
FIGS. 2 and 4. On the other hand, as can be seen in FIGS. 3 and 5, with the 
ESP protocol, authentication skips the IP header and the final part of the ESP 
trailer, which contains the authentication data. In the ESP protocol, encryption 

5 skips both the IP and ESP headers and the final part of the ESP trailer. 

Additional functionality is added to the router/server 103 in FIG. 1 through 
an Unsupported-Protocol Module 110 in order to provide interoperability between 
the NAT and those clients that are using a protocol that is not or cannot be 
directly supported by the NAT as, for example, the above-described IPSec AH 

10 and ESP protocols in both the transport and tunnel modes. For any such 

protocol that is not supported by NAT, clients need a client-implemented ALG to 
perform necessary modifications in packet payloads to compensate for NAT 
translations. To implement such an ALG, clients communicate with the 
router/server 103 to install entries in the NATs translation tables 111, stored in 

1 5 memory. For those entries installed at the request of a client (called client-ALG 
entries), NAT assumes that any necessary ALG is implemented at the 
corresponding client. On the other hand, for protocols that are supported by 
directly by NAT and whose entries are installed by NAT without an explicit 
request by a client (designated as NAT-ALG entries), NAT performs any ALG 

20 that may be necessary. NAT-ALG entries have the advantage of being 

transparent to end hosts, providing backward compatibility. This is only possible, 
however, for protocols for which the NAT implementation includes the necessary 
ALG. Client-ALG entries advantageously provide support for those protocols 
that cannot othenA^ise be supported. 

25 in order to enable NAT 107 to properly handle protocols which NAT does 

not directly support, NAT clients communicate with module 1 10 in router/server 
103 to define, for a specified protocol, the GPN in terms of the underlying 
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protocol and port number, the offsets of the source and destination fields from 
the end of the underlying protocol's header, the field lengths, and a value range 
for the GPN. The client also defines a GPN value that will be used to represent 
an "unspecified" GPN that, rather than being selected by the client, is to be 

5 selected by the NAT router/server. If the client specifies a protocol for which 
NAT 107 has the corresponding ALG, the router/server 103 returns an error code 
to the requesting client, and the client does not use client-ALG entries. 
Assuming that NAT does not have the corresponding ALG, module 1 10 in 
router/server 103 then allocates, for the specified protocol and up to a specified 

10 expiration time, a global IP address and global GPN for communications 
between the client's private IP address and private GPN and a given foreign 
address. In such an allocation request, the client needs to specify at least the 
protocol and the private IP address. The client may, however, declare the 
foreign IP address to be a value that matches any foreign IP address. The client 

15 leaves the global IP address and global GPN unspecified and may also leave the 
private GPN and/or the expiration time unspecified. If the client does not specify 
the private GPN, module 1 10 in router/server 103 selects the same value for the 
private and global GPNs. If the expiration time is left unspecified, module 1 10 in 
router/server 1 03 chooses the present time plus a default interval. Module 110 

20 then selects a global IP address/global GPN combination such that, for the 
specified protocol and foreign address, at most one private IP address/private 
GPN combination is associated with that global IP address/global GPN. All 
selected values are returned to the client and a translation table entry of the type 
shown in FIG. 6 is installed in the translation table 1 1 1 of NAT 107. 

25 As can be noted in FIG. 6, the entry in the translation table includes a 

protocol field 601, which provides an indication of the particular protocol being 
used for transmission; a field 602 for the private IP address of the particular 
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client 101-1 - 101 -N, for example, on the local network 102; a field 603 for 
private GPN for that particular client; a field 604 for the global IP address 
assigned by router/server 103 for this communication; a field 605 for the global 
GPN also assigned by router/sen/er 103; a field 606 for the foreign address with 

5 which the client is communicating; and a field 607 for the time at which lease of 
these global addresses expires. 

When NAT 107 receives a packet destined to a foreign IP address from a 
client, NAT 107 looks in its translation table for an entry whose protocol matches 
the protocol in the header of the packet, which private IP address and private 

10 GPN match the packet's source IP address and GPN, and whose foreign IP 
address matches the packet's destination IP address. If such an entry is found, 
NAT 107 translates the packet's source IP address and GPN from private to 
global values according to the matching entry. Otherwise, if NAT 107 has an 
ALG for the packet's protocol or if none is needed, NAT 1 07 automatically 

15 allocates a NAT-ALG entry in its translation table and translates the packet 
according to it, or else NAT 1 07 drops the packet. 

Conversely, when router/server 104 receives from a foreign address a 
packet destined to one of its global IP addresses, NAT 107 looks in its 
translation table for an entry whose protocol matches the protocol in the packet's 

20 header, whose global IP address and global GPN match the packet's destination 
IP address and GPN, and whose foreign IP address matches the packet's 
source IP address. If such an entry is found, NAT 107 translates the packet's 
destination IP address and GPN from the global values to the private values 
according to the matching entry. OthenA/ise, NAT 107 drops the packet. 

25 When a translation table entry reaches its expiration time, the entry is 

erased. Alternatively, the client may renew its lease through a request for either 
a default period of time or a requested period of time by fully specifying the 



14 



Brustoloni 10-6 



protocol, global GPN, global IP address, and foreign IP address as they already 
exist in the entry. Module 110 in router/server 103 upon recognizing that an 
entry for those parameter values already exists, renews the lease for the 
requested or default period of time. A client may alternatively request a de- 

5 allocation of an entry in the translation table upon completing communication 
with the foreign address specified in the entry. 

FIG. 7 is a flowchart showing some of the steps described above that are 
performed by the NAT router/server 103 to enable clients to use protocols that 
NAT 107 does not directly support. At step 701 , the NAT router/server receives 

10 from a client the definition of the GPN for a specified protocol. At step 702, a 
determination is made whether the router/server has an ALG for that protocol. If 
yes, at step 703, an error code is sent to the client. If, at step 702, the server 
does not have an ALG for the specified protocol, then, at step 704, in response 
to an allocation request from the client, the NAT router/server allocates for the 

1 5 given protocol, a global IP address and global GPN for communication with a 
given foreign address using a given private IP address and private GPN until a 
given or default expiration time. At step 705, an entry is installed in the NAT'S 
translation table and the allocated values are returned to the client. At step 706, 
the NAT server receives a packet having a destination address of the specified 

20 foreign address and using the specified protocol. At step 707, the NAT 

translates the private IP address/GPN source data to the global IP address/GPN 
according to translation table. Thereafter, or in parallel, at step 708, the NAT 
router/server receives a packet from the specified foreign address that is 
addressed to the global IP address with the global GPN and using the specified 

25 protocol. At step 709, the NAT, finding the appropriate entry in its translation 
table, translates the global IP address/GPN destination data to the private IP 
address/GPN. Following step 707 or 709, at step 710, the packet is fonwarded to 
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its destination. At step 71 1 , a determination is made wiietiier the current time 
has exceeded the specified expiration time of the entry. If not, pacl<et 
processing to and from the client continues. If yes, at step 712, the entry is 
deleted. 

5 The preceding methodology can be applied to the previously described 

unsupported IPSec protocol. In addition to the AH and ESP protocols in the 
tunnel or transport mode, the ISAKMP (Internet Security Association and Key 
Management Protocol) (see, e.g., D. Maughan, M. Schertler, M. Schneider and 
J. Turner, "Internet Security Association and Key Management Protocol 

10 (ISAKMP)," IETF, RFC 2408, Nov. 1998), is part of the IPSec protocol suite used 
by IPSec peers to negotiate which security services to implement (e.g., 
authentication and/or encryption) and which algorithms and keys to use. In 
addition to MD5 (see, e.g., C. Madson and R. Glenn, "The Use of HMAC-MD5- 
96 within ESP and AH," IETF, RFC 2403, Nov. 1998) and SHA (see, e.g., C. 

15 Madson and R. Glenn, "The Use of HMAC-SHA-1-96 within ESP and AH," IETF, 
RFC 2404, Nov. 1998) for authentication and DES (see, e.g., C. Madson and N. 
Doraswamy, "The ESP DES-CBC Cipher Algorithm with Explicit IV," IETF, RFC 
2405, Nov. 1998) for encryption, IPSec implementations may support other 
algorithms. The choice of services, algorithms, and keys is called a security 

20 association (SA). The framework for SA negotiation is defined by ISAKMP. 

ISAKMP is layered on top of UDP and uses UDP port 500 for both its source and 
destination. IPSec's negotiation is more specifically defined by IKE (Internet Key 
Exchange) (see, e.g., D. Harkins and D. Carrel, "The Internet Key Exchange 
(IKE)," IETF, RFC 2409, Nov. 1998). An IPSec packet's SA is uniquely identified 

25 by the protocol (AH or ESP) and destination IP address in the IP header, in 
conjunction with the SPI (Security Parameters Index), a 32-bit field in the AH or 
ESP header. 

16 



Brustoloni 10-6 

During the negotiation governed by the ISAKMP protocol, the GPN is an 
initiator cookie, a 64-bit field present in all ISKAMP packets during a negotiation 
session. Clients declare to the router/server that ISAKMP GPNs have a 0-bit 
offset from the end of the UDP header both for source and destination, and have 

5 a 64-bit length. The router/server thus knows where the GPN field begins and 
how many bits it occupies. Before using an initiator cookie in an ISAKMP 
negotiation, a local client 101-1 - 101-N leases the global IP address and cookie 
from the router/server 103, leaving both private and global GPN unspecified. 
This prevents NAT demultiplexing errors due to two or more of the local clients 

10 101-1 ~ 101-N using the same global IP address and cookie to communicate 
with a same foreign address using the same protocol. Because the client leaves 
both the private and global GPNs unspecified, the router/server 103 chooses 
them to be the same. The NAT thus translates only IP addresses, the cookie 
being translated to its same value. 

15 For the IPSec AH and ESP protocols, the underlying protocol is IP, and 

the GPN is the incoming SPl. For these protocols clients declare to the server 
that the GPN has a 0-bit offset from the end of the IP header both for source and 
destination, and has a 32-bit length. Before an SPl is selected in an ISAKMP 
negotiation, the incoming SPl is leased from router/server 103, again leaving 

20 both the private and global GPN unspecified. As with the initiator cookie, this 
guarantees that no two clients will be using the same SPl to communicate with 
the same foreign IP address using the same protocol, thereby avoiding potential 
demultiplexing errors. By leaving both the private and global GPNs unspecified, 
router/server 103 chooses them to be the same. Thus, as with the cookie, NAT 

25 107 translates only IP addresses and translates incoming SPIs to the same 
values. 
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Since, as previously described, due to the proper lack of access to the 
authentication and encryption codes used in a secure IPSec protocol-based 
communication, the NAT is unable to perform any ALG for IPSec packets. 
Rather, an IPSec ALG is installed in clients to compensate for the effects of the 

5 NAT'S IP address translations in IPSec packets. Such an ALG is possible at a 
client because the ALG is co-located with one of the IPSec endpoints and 
revealing the secret keys used in the secure transmission to the ALG does not 
violate end-to-end security. Without an ALG, however, a packet will be dropped 
when it arrives at its foreign address destination due to the deleterious effect that 

10 the NAT translation causes upon packet authentication verification and 

TCP/UDP checksum calculations. Accordingly, in order to avoid the effects of 
NAT translations, module 109 in the client modifies each outgoing packet before 
authentication and encryption to pre-compensate for those translation-induced 
effects and performs any ALG that might be necessary but which cannot be 

1 5 performed by the NAT. Similarly, after each incoming packet from the foreign 
address is authenticated and decrypted, any necessary ALG is processed by 
module 109 in the client and the packet is modified to post-compensate for the 
effects of the NAT translations. 

For full interoperability with NAT, clients using an unsupported protocol 

20 such as the IPSec security protocol suite, should follow the prescribed 
methodology when the source IP address is private but the destination IP 
address is global, or vice-versa. In such cases, as when as previously described 
the clients are connected on a private network, NAT is necessary. The following 
procedures should then be followed when using IPSec: 

25 1 . As previously described, before using an initiator cookie in an ISAKMP 

negotiation, the client leases a global IP address and cookie from router/server 
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103 to prevent NAT demultiplexing errors due to two or more local clients from 
using the same global IP address and cookie, 

2. For similar reasons, and as previously noted, before selecting an 
incoming SPI in an ISAKMP negotiation, the client leases the incoming SPI from 

5 the router/server 103, keeping the global IP address as in the first step above. 

3. For each outgoing packet, before authentication and encryption, the 
following steps are performed: 

(!) in the transport mode, replace the source port number by a 
global port number since the NAT will not translate that port number in the 
10 TCP or UDP header; 

(ii) in the tunnel mode, replace the encapsulated source IP address 
and port number by a global IP address and port number so that when the 
packet is decapsulated at the receiving end, a reply packet can properly 
have as its destination address that global address and global port 

15 number rather than the unaddressable private IP address on local network 

102; 

(iii) modify the TCP or UDP checksum by adding to the TCP or 
UDP checksum incorporated in the TCP or UDP header: (a) the difference 
between the global and private source IP addresses, and (b) the 

20 difference between the global and private source port numbers in order to 

compensate for the changes made to the packet in these steps or that will 
be made to the packet by the NAT translation; and 

(iv) process any ALG that may be necessary. 

4. Then, for the AH protocol, given that NAT will be translating the source 
25 IP address to the previously leased global IP address, compute the packet's AH 

authentication data as if the source IP address were equal to that global IP 
address and incorporate that authentication data into the AH header. 
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5. As previously noted, periodically renew leases for global IP addresses, 
initiator cookies, incoming SPIs, and global port nunnber, while needed. 

From step 4, when NAT performs its translation and the packet is received 
at its destination at the foreign address, the packet will be properly authenticated 
5 if no transmission errors have occurred. From step 3, when the TCP or UDP 
checksum is computed over the received authenticated and decrypted packet, it 
will match, absent a transmission error, the modified TCP or UDP checksum that 
is incorporated in the TCP or UDP header, at the client, before authentication 
and encryption. 

10 For incoming packets, steps 3 and 4 are replaced as follows: 

3'. For the AH protocol, compute each packet's authentication data as if 
the destination IP address were equal to the global IP address, since it was with 
that global IP address as the destination that the authentication data was 
originally computed when the packet was sent from the foreign address. 
15 4\ After authentication and decryption, the following steps are performed: 

(i') process any necessary ALG; 

(ii') in the transport mode, replace the global destination port 
number by the corresponding private port number, since NAT did not 
perform such translation; 

20 (iii') in the tunnel mode, replace in the decapsulated packet the 

global destination IP address and port number by the corresponding 
private address and port number, since such translations are not 
performed by NAT; and 

(iv') subtract from the TCP or UDP checksum in the packet (a) the 

25 difference between global and private destination IP addresses, and (b) 

the difference between global and private destination port number, to 
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compensate for the translations made in the packet by the client or by 
NAT. 

When the client computes the checksum over the received packet after 
translations made by NAT and steps (i') through (iv') above, the checksum will be 

5 correct, absent a transmission error. 

With reference to the flowchart in FIGS. 8-10, the steps from a local 
client's standpoint are shown that provide interoperability of NAT and IPSec, as 
described above. At step 801, the global IP address and initiator cookie are 
leased from the NAT router/server prior to an ISAKMP negotiation. At step 802, 

10 the incoming SPI is similarly leased from the NAT router/server. At step 803, a 
determination is made whether there is a packet to be processed under the 
IPSec protocol. If not, the program flow is fed back to step 803 until there is a 
packet to process. If, at step 803, there is a packet to be processed, then, at step 
806, a determination is made whether the leases have expired. If yes, then, at 

15 step 807, the leases are renewed with the NAT router/server. If the leases have 
not expired, or after the leases have been renewed, a determination is made, at 
step 808, whether the packet is incoming (received from the local network) or 
outgoing (received from the client's IP/TCP/UDP output). If it is an outgoing 
packet, then, at step 809, a determination is made whether the transport or 

20 tunnel mode is to be used. If the transport mode is to be used, at step 810, the 
source port number in the packet is replaced with a global port number. If the 
tunnel mode is to be used, then, at step 81 1, the encapsulated source IP 
address and port number are replaced by the global IP address and global port 
number. After either steps 810 or 81 1, at step 812 (FIG. 9), the difference 

25 between the global and private source IP addresses and the difference between 
the global and private source port numbers are added to the TCP or UDP 
checksum. At step 813, any necessary ALGs are processed. At step 814, a 
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determination is made whether the AH or ESP protocol is being used. If the AH 
protocol is being used, then, at step 815, the packet's authentication data is 
computed as if the source IP address were equal to the global IP address. If the 
ESP protocol is being used, at step 816, the authentication and encryption data 

5 for the modified packet is computed. After either steps 815 or 816, at step 817, 
the packet is formulated according to the protocol and mode and, at step 818, 
the packet is sent to the NAT router/server. The program flow then returns to 
step 803 (FIG. 8) for processing of another packet. If, at step 808, an incoming 
packet is to be processed, then, at step 819 (FIG. 10), a determination is made 

10 whether the protocol of that packet is AH or ESP. If the protocol is AH, at step 
820, the packet's authentication data is computed as if the destination IP 
address were equal to the global IP address. If the protocol is ESP, at step 821 , 
authentication and decryption are performed on the received incoming packet. 
Following either steps 820 or 821 , at step 822, any necessary ALGs are 

15 processed. At step 823, a determination is made whether the transport or tunnel 
modes were used. If the transport mode was used, then at step 824, the global 
destination port number is replaced by the corresponding private port number. If 
the tunnel mode was used, then at step 825, the global destination IP address 
and port number are replaced in the decapsulated packet by the corresponding 

20 private address and port number. Following either steps 824 or 825, at step 826, 
the difference between the global and private destination IP addresses and the 
difference between the global and private port numbers are subtracted from the 
TCP or UDP checksum in the packet. At step 827, the modified packet is 
passed to an IP/TCP/UDP input process. The program flow then returns to step 

25 803 (FIG. 8) for processing of another packet. 

Although described in conjunction with the IPSec security protocol, it 
should be apparent to one skilled in the art that network address translation can 
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be extended to handle any protocol that the NAT and its associated server do 
not themselves support. Similarly the pre and post compensation and the 
incorporation of necessary ALGs at a client that is using a protocol not supported 
by the NAT and which the client needs to connect to the Internet or other packet- 

5 based network can likewise be extended to any such unsupported protocol. 

Although router/server 107 are shown as a single entity, one skilled in the 
art will realize that the router and server could be separate entities and that the 
NAT and the server could be on separate entities. Further, the client modules 
109 and server module 1 10 are described as software modules and are 

10 preferably implemented as such, but they also could be implemented in 

hardware. As software modules, they could be implemented in RAM, ROM, or 
any other computer readable medium. 

The foregoing merely illustrates the principles of the invention. It will thus 
be appreciated that those skilled in the art will be able to devise various 

15 arrangements which, although not explicitly described or shown herein, embody 
the principles of the invention and are included within its spirit and scope. 
Furthermore, all examples and conditional language that were recited herein 
were principally intended expressly to be only for pedagogical purposes to aid 
the reader in understanding the principles of the invention and the concepts 

20 contributed by the inventor(s) to furthering the art, and are to be construed as 
being without limitation to such specifically recited examples and conditions. 
Moreover, all statements herein reciting principles, aspects, and embodiments of 
the invention, as well as specific examples thereof, are intended to encompass 
both structural and functional equivalents thereof. Additionally, it is intended that 

25 such equivalents include both currently known equivalents as well as equivalents 
developed in the future, i.e., any elements developed that perform the same 
function, regardless of structure. 
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Thus, for example, it will be appreciated by those skilled in the art that the 
block diagrams herein represent conceptual views embodying the principles of 
the invention. Similarly, it will be appreciated that any flowcharts, and the like 
represent various processes which may be substantially represented in computer 

5 readable medium and so executed by a computer or processor, whether or not 
such computer or processor is explicitly shown. 

The functions of the various elements shown in the FIGS., may be 
provided through the use of dedicated hardware as well as hardware capable of 
executing software in association with appropriate software. When provided by a 

10 processor, the functions may be provided by a single dedicated processor, by a 
single shared processor, or by a plurality of individual processors, some of which 
may be shared. 

In the claims hereof any element expressed as a means for performing a 
specified function is intended to encompass any way of performing that function 

1 5 including, for example, a) a combination of circuit elements which performs that 
function or b) software in any form, including, therefore, firmware, microcode or 
the like, combined with appropriate circuitry for executing that software to 
perform the function. The invention as defined by such claims resides in the fact 
that the functionalities provided by the various recited means are combined and 

20 brought together in the manner which the claims call for. Applicant thus regards 
any means which can provide those functionalities as equivalent as those shown 
herein. 
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The invention claimed is: 



1 1. A method comprising: 

2 receiving a request from a client at a network address translator (NAT) 

3 that defines for a protocol not directly supported by the NAT a generalized port 

4 number (GPN) associated with that unsupported protocol and its location in each 

5 packet; 

6 creating an entry in a translation table of the NAT that defines for that 



7 protocol an association between a client's private IP address and GPN, a NATs 

8 assigned global IP address and GPN, and a foreign IP address, said entry being 

9 used for translating in outgoing packets received by the NAT from the client 

10 using that protocol and having the foreign IP address as their destination, the 

1 1 client's private source IP address and GPN to the NATs global IP address and 

12 GPN, respectively, and for translating in incoming packets sent from the foreign 

13 IP address using that protocol to the NATs global destination IP address and 

14 GPN, the NAT'S global destination IP address and GPN to the client's private 

15 destination IP address and GPN, respectively. 



1 2. A method comprising; 

2 receiving a request from a client at a network address translator (NAT) 

3 that defines for a protocol not directly supported by the NAT a generalized port 

4 number (GPN) associated with that unsupported protocol and its location in each 

5 packet; 

6 creating an entry in a translation table of the NAT that defines for that 

7 protocol an association between a client's private IP address and GPN, NATs 

8 assigned global IP address and GPN, and a foreign IP address; and 

9 in outgoing packets received by the NAT from the client using that 

LO protocol and having the foreign IP address as their destination, translating in 
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1 1 accordance with the entry, the client's private source IP address and GPN to the 

12 NAT'S global IP address and GPN, respectively. 

1 3. A method comprising: 

2 receiving a request from a client at a network address translator (NAT) 

3 that defines for a protocol not directly supported by the NAT a generalized port 

4 number (GPN) associated with that unsupported protocol and its location in each 

5 packet; 

6 creating an entry in a translation table of the NAT that defines for that 

7 protocol an association between a client's private IP address and GPN, a NATs 

8 assigned global IP address and GPN, and a foreign IP address; and 

9 in incoming packets received by the NAT and sent from the foreign IP 

10 address using that protocol to the NATs global destination IP address and GPN, 

1 1 translating in accordance with the entry, the NATs global destination IP address 

12 and GPN to the clients private destination IP address and GPN, respectively. 

1 4. The method of claims 1 , 2 or 3 wherein the entry further defines an 

2 expiration time until which the entry is valid for translating packets. 

1 5. The method of claims 1 , 2 or 3 wherein the unsupported protocol is a 

2 protocol in the IP Security (IPSec) security protocol suite. 

1 5. The method of claim 5 wherein the unsupported protocol in the iPSec 

2 security suite is the Internet Security Association and Key Management Protocol 

3 (ISAKMP) and the GPN is an initiator cookie leased from the NAT to be unique 

4 to the client. 

1 7. The method of claim 6 wherein the leased initiator cookie is chosen by 

2 the NAT to be used as both the client's GPN and the NATs GPN. 

1 8. The method of claim 5 wherein the unsupported protocol in the IPSec 

2 security suite is the AH or ESP protocol in either the tunnel or transport modes, 
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3 and the GPN is an incoming Security Parameter Index (SRI) leased from the 

4 NAT to be unique to the client. 

1 9. The method of claim 8 wherein the leased SRI is chosen by the NAT to 

2 be used as both the client's GRN and the NAT's GRN. 

1 1 0. A network address translator (NAT) comprising: 

2 means for receiving a request from a client that defines for a protocol not 

3 directly supported by the NAT a generalized port number (GPN) associated with 

4 that unsupported protocol and its location in each packet; 

5 memory means for storing a translation table; 

6 means for creating an entry in the translation table that defines for that 



7 protocol an association between a client's private IP address and GRN, a NAT's 

8 assigned global IP address and GPN, and a foreign IP address, said entry being 

9 used for translating in outgoing packets received by the NAT from the client 

10 using that protocol and having the foreign IP address as their destination, the 

1 1 client's private source IP address and GPN to the NAT's global IP address and 

1 2 GRN, respectively, and for translating in incoming packets sent from the foreign 
] 3 IP address using that protocol to the NAT's global destination IP address and 

14 GPN, the NAT'S global destination IP address and GPN to the client's private 

15 destination IP address and GPN, respectively. 



1 11. A network address translator (NAT) comprising: 

2 means for receiving a request from a client at a network address 

3 translator (NAT) that defines for a protocol not directly supported by the NAT a 

4 generalized port number (GRN) associated with that unsupported protocol and 

5 its location in each received packet; 

6 memory means for storing a translation table; 
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7 means for creating an entry in tine translation table tliat defines for that 

8 protocol an association between a client's private IP address and GPN, NAT's 

9 assigned global IP address and GPN, and a foreign IP address; and 

10 means for, in outgoing packets received by the NAT from the client using 

1 1 that protocol and having the foreign IP address as their destination, translating in 

12 accordance with the entry, the client's private source IP address and GPN to the 

13 NAT'S global IP address and GPN, respectively. 

1 12. A network address translator (NAT) comprising: 

2 means for receiving a request from a client that defines for a protocol not 

3 directly supported by the NAT a generalized port number (GPN) associated with 

4 that unsupported protocol and its location in each packet; 

5 memory means for storing a translation table; 

6 means for creating an entry in the translation table that defines for that 

7 protocol an association between a client's private IP address and GPN, a NAT's 

8 assigned global IP address and GPN, and a foreign IP address; and 

9 means for, in incoming packets received by the NAT and sent from the 

1 0 foreign IP address using that protocol to the NAT's global destination IP address 

1 1 and GPN, translating in accordance with the entry, the NAT's global destination 

12 IP address and GPN to the client's private destination IP address and GPN, 

13 respectively. 

1 13. The NAT of claims 1 0, 1 1 or 1 2 wherein the entry further defines an 

2 expiration time until which the entry is valid for translating packets. 

1 14. The NAT of claims 1 0, 1 1 or 12 wherein the unsupported protocol is a 

2 protocol in the IP Security (IPSec) security protocol suite. 

1 15. The NAT of claim 14 wherein the unsupported protocol in the IPSec 

2 security suite is the Internet Security Association and Key Management Protocol 
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3 (ISAKMP) and the GPN is an initiator cookie leased from the NAT to be unique 

4 to the client. 

1 16. The NAT of claim 15 wherein the leased initiator cookie is chosen by 

2 the NAT to be used as both the client's GPN and the NATs GPN. 

1 17. The NAT of claim 14 wherein the unsupported protocol in the IPSec 

2 security suite is the AH or ESP protocols in tunnel or transport modes, and the 

3 GPN is an incoming Security Parameter Index (SPI) leased from the NAT to be 

4 unique to the client. 

1 18. The NAT of claim 17 wherein the leased SPI is chosen by the NAT to 

2 be used as both the client's GPN and the NAT's GPN. 

1 19. A computer readable media tangibly embodying a program of 

2 instructions executable by a computer to perform a method at a network address 

3 translator (NAT), the method comprising: 

4 receiving a request from a client that defines for a protocol not directly 

5 supported by the NAT a generalized port number (GPN) associated with that 

6 unsupported protocol and its location in each packet; 

7 creating an entry in a translation table of the NAT that defines for that 



8 protocol an association between a client's private IP address and GPN, a NAT's 

9 assigned global IP address and GPN, and a foreign IP address, said entry being 

10 used for translating in outgoing packets received by the NAT from the client 

1 1 using that protocol and having the foreign IP address as their destination, the 

12 client's private source IP address and GPN to the NATs global IP address and 

13 GPN, respectively, and for translating in incoming packets sent from the foreign 

14 IP address using that protocol to the NATs global destination IP address and 

15 GPN, the NAT'S global destination IP address and GPN to the client's private 

16 destination IP address and GPN, respectively. 
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1 20. A computer readable media tangibly embodying a program of 

2 instructions executable by a computer to perform a method at a network address 

3 translator (NAT), the method comprising: 

4 receiving a request from a client that defines for a protocol not directly 

5 supported by the NAT a generalized port number (GPN) associated with that 

6 unsupported protocol and its location in each packet; 

7 creating an entry in a translation table of the NAT that defines for that 

8 protocol an association between a client's private IP address and GPN, NAT's 

9 assigned global IP address and GPN, and a foreign IP address; and 

10 in outgoing packets received by the NAT from the client using that 

1 1 protocol and having the foreign IP address as their destination, translating in 

12 accordance with the entry, the client's private source IP address and GPN to the 

13 NAT'S global IP address and GPN, respectively. 

1 21 . A computer readable media tangibly embodying a program of 

2 instructions executable by a computer to perform a method at a network address 

3 translator (NAT), the method comprising: 

4 receiving a request from a client that defines for a protocol not directly 

5 supported by the NAT a generalized port number (GPN) associated with that 

6 unsupported protocol and its location in each packet; 

7 creating an entry in a translation table of the NAT that defines for that 

8 protocol an association between a client's private IP address and GPN, a NAT's 

9 assigned global IP address and GPN, and a foreign IP address; and 

10 in incoming packets received by the NAT and sent from the foreign IP 

1 1 address using that protocol to the NAT's global destination IP address and GPN, 

12 translating in accordance with the entry, the NAT's global destination IP address 

13 and GPN to the client's private destination IP address and GPN, respectively. 
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1 22. The media of claims 19, 20 or 21 where in the method the entry 

2 further defines an expiration time until which the entry is valid for translating 

3 packets. 

1 23. The media of claims 19, 20 or 21 where in the method the 

2 unsupported protocol is a protocol in the IP Security (IPSec) security protocol 

3 suite. 

1 24. The media of claim 23 wherein the unsupported protocol in the IPSec 

2 security suite is the Internet Security Association and Key Management Protocol 

3 (ISAKMP) and the GPN is an initiator cookie leased from the NAT to be unique 

4 to the client. 

1 25. The media of claim 24 wherein the leased initiator cookie is chosen 

2 by the NAT to be used as both the client's GPN and the NAT's GPN. 

1 26. The media of claim 23 wherein the unsupported protocol in the IPSec 

2 security suite is the AH or ESP protocol in either the tunnel or transport modes, 

3 and the GPN is an incoming Security Parameter Index (SPI) leased from the 

4 NAT to be unique to the client. 

1 27. The method of claim 26 wherein the leased SPI is chosen by the NAT 

2 to be used as both the client's GPN and the NAT's GPN. 
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Abstract of the Disclosure 

Clients that are connected on a private network and which are assigned a 
private IP address that is not routable on the Internet can connect to the Internet 
through a router/server that includes a network address translator (NAT). For 

5 outgoing packets, the NAT translates the client's private source IP address and 
generalized port number (GPN) to the NAT'S global IP address and GPN. For 
incoming packets sent to the NAT's global IP address and GPN, the NAT translates 
the global destination IP address and GPN to the client's private IP address and 
GPN. For protocols which cannot be directly supported by the NAT, such as those 

10 in the IPSec security protocol suite, the NAT is extended by creating in the NATs 
translation table an entry that associates, for a specific unsupported protocol, a 
client's private IP address and GPN, the NATs global IP address and GPN, and a 
foreign address on the Internet, that is valid until a specified or default expiration 
time. Outgoing packets from the client to that foreign address and incoming packets 

1 5 from that foreign address to the NATs global IP address and GPN are translated 
according to the entry until the entry expires. In associations with these translations 
to outgoing and incoming packets, the client implements any Application Layer 
Gateway (ALG) that would otherwise be implemented at the NAT. Further, at the 
client, outgoing packets are modified before being transmitted so as to pre- 

20 compensate for the effects of the translations. Incoming packets at the client from 
the NAT are similarly modified so as to post-compensate for the effects of the 
translations. For the IPSec protocol, these modification include adjusting the 
checksum in the TCP or UDP header to account for IP address and TCP or UDP 
port number translations. 
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